SEP 2 5 2006

Blakely, Sokoloff, Taylor & Zafman LLP (714) 557-3800 Title: DATA PACKET ARITHMETIC LOGIC DEVICES AND

**METHODS** 

1st Named Inventor: Corey Gee Application No.: 10/602,349

Sheet: 1/10

Docket No.: 42P14357

1/10





FIG. 4

Blakely, Sokoloff, Taylor & Zafman LLP (714) 557-3800 Title: DATA PACKET ARITHMETIC LOGIC DEVICES AND METHODS

1st Named Inventor: Corey Gee Application No.: 10/602,349

Sheet: 2/10

2/10

Docket No.: 42P14357

Instruction Description

[-C][-M] RZ, RX, RY Syntax: PADD -I[-C][-M] RZ, RX, <UI8 :immediate> PADD PADD

-N[-C][-M] RZ, RX, RY, <UI5 : start>, <UI5 : stop>

-N-I[-C][-M] RZ, RX, <UI8: immediate>, <UI5: start> PADD

RX, RY are the source data registers

RZ is the destination register

<UI8: immediate> specifies the value of an immediate operand

<UI5: start> specifies start of bit field to be modified

<UI5: stop> specifies end of bit field to be modified

-C indicates addition with carry in

-M indicates addition modulo 2<sup>n</sup>-1

N indicates that addition affects only a bit field

-I indicates that second operand is supplied as an immediate value

Blakely, Sokoloff, Taylor & Zafman LLP (714) 5
Title: DATA PACKET ARITHMETIC LOGIC DEVICES AND
METHODS (714) 557-3800

1st Named Inventor: Corey Gee Application No.: 10/602,349 Sheet: 3/10

Docket No.: 42P14357

3/10

| Option Used                                                           | Operation                                                                 |
|-----------------------------------------------------------------------|---------------------------------------------------------------------------|
| PADD RZ, RX, RY                                                       | RZ = RX + RY                                                              |
| PADD -C RZ, RX, RY                                                    | RZ = RX + RY + Cin                                                        |
| PADD -I RZ, RX, <u18: immediate=""></u18:>                            | RZ = RX + <immediate></immediate>                                         |
| PADD -N RZ, RX, RY, <ui5: start="">, <ui5: stop=""></ui5:></ui5:>     | RZ = { RX[31:stop], (RX[stop:start] + RY[length] +                        |
|                                                                       | RX[start:0]) modulo 2 <sup>length</sup> }                                 |
|                                                                       | Where length = stop - start + 1                                           |
| PADD -M RZ, RX, RY                                                    | $RZ = (RX + RY) \text{ modulo } 2^{n} - 1$                                |
| PADD -N -I RZ, RX, <ui8: immediate="">, <ui5: start=""></ui5:></ui8:> | $RZ = \{ (RX[31:start], + immediate[31-start: 0]) modulo 2^{31-start+1},$ |
|                                                                       | RX[start: 0] }                                                            |
|                                                                       | In this case, a stop is assumed to be 31.                                 |

Blakely, Sokoloff, Taylor & Zafman LLP (714) 557-3800 Title: DATA PACKET ARITHMETIC LOGIC DEVICES AND METHODS

1st Named Inventor: Corey Gee Application No.: 10/602,349 Sheet: 4/10

Docket No.: 42P14357

4/10

Syntax: SMAD [-A] [-M] RZ, RX, RY, <UI2: Length>, <UI2: Num Ops>

SMAD

RZ is the destination register

RX and RY are source data registers

-A option is used to accumulate results where RZ is used as the accumulator

-M option results in a modulo 2<sup>n</sup>- 1 addition

<UI2: Length> indicates the data widths

0: 8 bit operands, where each register is assumed to contain 4 8-bit operands

1: 16 bit operands, where each register is assumed to contain 2 16-bit operands

2: 32 bit operands

3: unused

<UI2: Num Ops> indicates the number of operands to be used in the addition

0: 2 source operands RX and RY

1: 3 source operands RX, RX+1 and RY

2: 3 source operands RX, RY and RY+1

3: 4 source operands RX, RY, RX+1 and RY+1

Blakely, Sokoloff, Taylor & Zafman LLP (714) 557-3800
Title: DATA PACKET ARITHMETIC LOGIC DEVICES AND
METHODS
1st Named Inventor: Corey Gee
Application No.: 10/602,349
Sheet: 5/10

5/10

| Option Used                 | Operation                                         |
|-----------------------------|---------------------------------------------------|
| SMAD RZ, RX, RY, 2, 0       |                                                   |
| SMAD -A RZ, RX, RY, 2, 0    | RZ = RZ + RX + RY                                 |
| SMAD RZ, RX, RY, 2,3        | RZ = RX + RY + (RX+1) + (RY+1)                    |
| SMAD RZ, RX, RY, 0, 0       | RZ = RX[7:0] + RX[15:8] + RX[23:16] + RX[31:24] + |
|                             | RY[7:0] + RY[15:8] + RY[23:16] + RY[31:24]        |
| SMAD -M RZ, RX, RY, 2, 0    | $RZ = (RX + RY) \text{ modulo } 2^n - 1$          |
| SMAD -A -M RZ, RX, RY, 2, 0 | $RZ = (RZ + RX + RY) \mod 2^{n} - 1$              |
|                             |                                                   |

Blakely, Sokoloff, Taylor & Zafman LLP (714) 557-3800 Title: DATA PACKET ARITHMETIC LOGIC DEVICES AND METHODS

1st Named Inventor: Corey Gee Application No.: 10/602,349 Sheet: 6/10





Blakely, Sokoloff, Taylor & Zafman LLP (714) 557-3800

Title: DATA PACKET ARITHMETIC LOGIC DEVICES AND

**METHODS** 

1st Named Inventor: Corey Gee Application No.: 10/602,349

Sheet: 7/10

Docket No.: 42P14357

7/10

| m + n      | mask (32b) | mask (32b) |
|------------|------------|------------|
| 0: 00000   | 11111110   | 00000001   |
| 1: 00001   | 11111100   | 00000011   |
| 2: 00010   | 11111000   | 00000111   |
| •          | •          | •          |
| •          | •          | •          |
| 30: 1 1110 | 10000000   | 01111111   |
| 31: 1_1111 | 00000000   | 11111111   |

FIG. 6

| Carry bits of special consideration in "32-b CSA"                  |                                                                            |                                                                      |                                                         |
|--------------------------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------|
| carry bit                                                          | output from                                                                | input to                                                             | not propagated for modulo 2 <sup>n</sup> addition, n=?  |
| c[8]<br>co_8<br>c[16]<br>co_16<br>c[24]<br>co_24<br>c[32]<br>co_32 | 702-7<br>702-7<br>702-15<br>702-15<br>702-23<br>702-23<br>702-31<br>702-31 | 704-8<br>702-8<br>704-0<br>702-16<br>704-8<br>702-24<br>708<br>702-0 | 8<br>8, 16<br>8, 16<br>8<br>8<br>8, 16, 32<br>8, 16, 32 |

FIG. 11

| Carry bits of special consideration in "16-b CSA" |                                    |                                  |                                                                                      |  |
|---------------------------------------------------|------------------------------------|----------------------------------|--------------------------------------------------------------------------------------|--|
| carry bit                                         | output from                        | input to                         | not propagated for<br>modulo 2 <sup>n</sup> addition, n=?<br>(n = 32 not applicable) |  |
| c[8]<br>co1_8<br>c1[16]<br>co1_16                 | 704-7<br>704-7<br>704-15<br>704-15 | 706-0<br>704-8<br>704-0<br>704-0 | 8<br>8<br>8, 16<br>8, 16                                                             |  |

FIG. 12

| Carry bits of special consideration in "8-b CSA" |                |                |                                                                                          |
|--------------------------------------------------|----------------|----------------|------------------------------------------------------------------------------------------|
| carry bit                                        | output from    | input to       | not propagated for<br>modulo 2 <sup>n</sup> addition, n=?<br>(n = 32, 16 not applicable) |
| c2[8]<br>co2_8                                   | 706-7<br>706-7 | 706-0<br>706-0 | 8<br>8                                                                                   |

FIG. 13

Blakely, Sokoloff, Taylor & Zafman LLP (714) 557-3800 Title: DATA PACKET ARITHMETIC LOGIC DEVICES AND

**METHODS** 

1st Named Inventor: Corey Gee

Application No.: 10/602,349

Sheet: 8/10



Blakely, Sokoloff, Taylor & Zafman LLP (714) 557-3800 Title: DATA PACKET ARITHMETIC LOGIC DEVICES AND

METHODS

1st Named Inventor: Corey Gee Application No.: 10/602,349

Sheet: 9/10





(714) 557-3800 Blakely, Sokoloff, Taylor & Zafman LLP

Title: DATA PACKET ARITHMETIC LOGIC DEVICES AND METHODS

1st Named Inventor: Corey Gee Application No.: 10/602,349 Sheet: 10/10



